home *** CD-ROM | disk | FTP | other *** search
/ Language/OS - Multiplatform Resource Library / LANGUAGE OS.iso / scheme / pcscheme / geneva / sources.exe / SAMPLES / PENROSE.SW < prev    next >
LaTeX Document  |  1992-12-10  |  4.7 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: LaTeX Document (document/latex).

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert LaTeX Document (document/latex) magic Supported
1% dexvert Text File (text/txt) fallback Supported
100% file LaTeX document text default
99% file LaTeX document, ASCII text, with CRLF line terminators default
100% TrID LaTeX 2e document (with rem) default
100% checkBytes Printable ASCII default
100% perlTextCheck Likely Text (Perl) default
100% siegfried fmt/281 LaTeX (Subdocument) default
100% detectItEasy Format: plain text[CRLF] default (weak)



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 25 2a 20 50 45 4e 52 4f | 53 45 2e 53 57 0d 0a 25 |%* PENRO|SE.SW..%|
|00000010| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000020| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000030| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000040| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000050| 2a 2a 2a 2a 2a 2a 2a 2a | 0d 0a 25 2a 09 09 09 09 |********|..%*....|
|00000060| 09 09 09 09 09 2a 0d 0a | 25 2a 09 09 50 43 20 53 |.....*..|%*..PC S|
|00000070| 63 68 65 6d 65 2f 47 65 | 6e 65 76 61 20 34 2e 30 |cheme/Ge|neva 4.0|
|00000080| 30 20 53 63 68 65 6d 65 | 20 63 6f 64 65 09 09 09 |0 Scheme| code...|
|00000090| 2a 0d 0a 25 2a 09 09 09 | 09 09 09 09 09 09 2a 0d |*..%*...|......*.|
|000000a0| 0a 25 2a 20 28 63 29 20 | 31 39 38 35 2d 31 39 38 |.%* (c) |1985-198|
|000000b0| 38 20 62 79 20 54 65 78 | 61 73 20 49 6e 73 74 72 |8 by Tex|as Instr|
|000000c0| 75 6d 65 6e 74 73 2c 20 | 49 6e 63 2e 20 53 65 65 |uments, |Inc. See|
|000000d0| 20 43 4f 50 59 52 49 47 | 48 54 2e 54 58 54 09 09 | COPYRIG|HT.TXT..|
|000000e0| 2a 0d 0a 25 2a 20 28 63 | 29 20 31 39 39 32 20 62 |*..%* (c|) 1992 b|
|000000f0| 79 20 4c 2e 20 42 61 72 | 74 68 6f 6c 64 69 20 26 |y L. Bar|tholdi &|
|00000100| 20 4d 2e 20 56 75 69 6c | 6c 65 75 6d 69 65 72 2c | M. Vuil|leumier,|
|00000110| 20 55 6e 69 76 65 72 73 | 69 74 79 20 6f 66 20 47 | Univers|ity of G|
|00000120| 65 6e 65 76 61 09 2a 0d | 0a 25 2a 09 09 09 09 09 |eneva.*.|.%*.....|
|00000130| 09 09 09 09 2a 0d 0a 25 | 2a 2d 2d 2d 2d 2d 2d 2d |....*..%|*-------|
|00000140| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000150| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000160| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000170| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2a |--------|-------*|
|00000180| 0d 0a 25 2a 09 09 09 09 | 09 09 09 09 09 2a 0d 0a |..%*....|.....*..|
|00000190| 25 2a 09 09 09 09 09 2a | 0d 0a 25 2a 09 09 09 09 |%*.....*|..%*....|
|000001a0| 09 09 09 09 09 2a 0d 0a | 25 2a 2d 2d 2d 2d 2d 2d |.....*..|%*------|
|000001b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001f0| 2a 0d 0a 25 2a 09 09 09 | 09 09 09 09 09 09 2a 0d |*..%*...|......*.|
|00000200| 0a 25 2a 20 43 72 65 61 | 74 65 64 20 62 79 3a 20 |.%* Crea|ted by: |
|00000210| 4c 61 72 72 79 20 42 61 | 72 74 68 6f 6c 64 69 09 |Larry Ba|rtholdi.|
|00000220| 09 44 61 74 65 3a 20 31 | 39 39 32 09 09 09 2a 0d |.Date: 1|992...*.|
|00000230| 0a 25 2a 20 52 65 76 69 | 73 69 6f 6e 20 68 69 73 |.%* Revi|sion his|
|00000240| 74 6f 72 79 3a 09 09 09 | 09 09 09 09 2a 0d 0a 25 |tory:...|....*..%|
|00000250| 2a 20 2d 20 31 38 20 4a | 75 6e 20 39 32 3a 09 52 |* - 18 J|un 92:.R|
|00000260| 65 6e 61 69 73 73 61 6e | 63 65 20 28 42 6f 72 6c |enaissan|ce (Borl|
|00000270| 61 6e 64 20 43 6f 6d 70 | 69 6c 65 72 73 2c 20 2e |and Comp|ilers, .|
|00000280| 2e 2e 29 09 09 09 2a 0d | 0a 25 2a 09 09 09 09 09 |..)...*.|.%*.....|
|00000290| 09 09 09 09 2a 0d 0a 25 | 2a 09 09 09 09 09 60 60 |....*..%|*.....``|
|000002a0| 49 6e 20 6e 6f 6d 69 6e | 65 20 6f 6d 6e 69 70 6f |In nomin|e omnipo|
|000002b0| 74 65 6e 74 69 69 20 64 | 65 69 27 27 09 2a 0d 0a |tentii d|ei''.*..|
|000002c0| 25 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |%*******|********|
|000002d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000002e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000002f0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000300| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 0d 0a 0d 0a 5c 64 6f |********|*....\do|
|00000310| 63 75 6d 65 6e 74 73 74 | 79 6c 65 5b 31 31 70 74 |cumentst|yle[11pt|
|00000320| 2c 61 34 2c 61 73 74 79 | 70 65 64 5d 7b 61 72 74 |,a4,asty|ped]{art|
|00000330| 69 63 6c 65 7d 0d 0a 5c | 74 69 74 6c 65 7b 50 65 |icle}..\|title{Pe|
|00000340| 6e 72 6f 73 65 20 54 69 | 6c 69 6e 67 73 7d 0d 0a |nrose Ti|lings}..|
|00000350| 5c 61 75 74 68 6f 72 7b | 4c 61 72 72 79 20 42 61 |\author{|Larry Ba|
|00000360| 72 74 68 6f 6c 64 69 20 | 5c 26 20 68 69 73 20 67 |rtholdi |\& his g|
|00000370| 61 6e 67 7d 0d 0a 5c 64 | 61 74 65 7b 5c 74 6f 64 |ang}..\d|ate{\tod|
|00000380| 61 79 7d 0d 0a 5c 73 65 | 74 6c 65 6e 67 74 68 7b |ay}..\se|tlength{|
|00000390| 5c 74 65 78 74 68 65 69 | 67 68 74 7d 7b 32 34 30 |\texthei|ght}{240|
|000003a0| 6d 6d 7d 0d 0a 0d 0a 5c | 6e 65 77 63 6f 6d 6d 61 |mm}....\|newcomma|
|000003b0| 6e 64 7b 5c 70 63 73 7d | 7b 7b 5c 73 63 20 50 63 |nd{\pcs}|{{\sc Pc|
|000003c0| 53 63 68 65 6d 65 7d 7d | 0d 0a 0d 0a 5c 62 65 67 |Scheme}}|....\beg|
|000003d0| 69 6e 7b 64 6f 63 75 6d | 65 6e 74 7d 0d 0a 5c 6d |in{docum|ent}..\m|
|000003e0| 61 6b 65 74 69 74 6c 65 | 0d 0a 7b 5c 73 6c 20 4d |aketitle|..{\sl M|
|000003f0| 79 20 77 61 72 6d 65 73 | 74 20 74 68 61 6e 6b 73 |y warmes|t thanks|
|00000400| 20 74 6f 20 53 68 61 6c | 6f 6d 20 45 6c 69 61 68 | to Shal|om Eliah|
|00000410| 6f 75 2c 20 77 68 6f 20 | 73 75 67 67 65 73 74 65 |ou, who |suggeste|
|00000420| 64 20 70 72 6f 67 72 61 | 6d 6d 69 6e 67 0d 0a 09 |d progra|mming...|
|00000430| 50 65 6e 72 6f 73 65 20 | 74 69 6c 69 6e 67 73 20 |Penrose |tilings |
|00000440| 69 6e 20 53 63 68 65 6d | 65 2e 7d 0d 0a 0d 0a 57 |in Schem|e.}....W|
|00000450| 65 20 77 69 6c 6c 20 64 | 65 76 69 73 65 20 72 65 |e will d|evise re|
|00000460| 63 75 72 73 69 76 65 20 | 70 72 6f 63 65 64 75 72 |cursive |procedur|
|00000470| 65 73 20 74 6f 20 64 72 | 61 77 20 50 65 6e 72 6f |es to dr|aw Penro|
|00000480| 73 65 20 74 69 6c 69 6e | 67 73 20 75 73 69 6e 67 |se tilin|gs using|
|00000490| 0d 0a 5c 70 63 73 2c 20 | 61 6e 64 20 64 69 73 70 |..\pcs, |and disp|
|000004a0| 6c 61 79 69 6e 67 20 74 | 68 65 20 72 65 73 75 6c |laying t|he resul|
|000004b0| 74 73 20 74 68 72 6f 75 | 67 68 20 7b 5c 73 63 20 |ts throu|gh {\sc |
|000004c0| 42 6f 72 6c 61 6e 64 7d | 27 73 20 5c 76 65 72 62 |Borland}|'s \verb|
|000004d0| 2b 42 47 49 2b 0d 0a 69 | 6e 74 65 72 66 61 63 65 |+BGI+..i|nterface|
|000004e0| 2e 0d 0a 0d 0a 50 65 6e | 72 6f 73 65 27 73 20 67 |.....Pen|rose's g|
|000004f0| 65 6e 69 75 73 20 77 61 | 73 20 74 6f 20 64 69 73 |enius wa|s to dis|
|00000500| 63 6f 76 65 72 20 74 77 | 6f 20 74 72 69 61 6e 67 |cover tw|o triang|
|00000510| 6c 65 73 2c 20 74 68 61 | 74 20 63 61 6e 0d 0a 65 |les, tha|t can..e|
|00000520| 61 63 68 20 62 65 20 63 | 75 74 20 69 6e 20 74 77 |ach be c|ut in tw|
|00000530| 6f 20 70 61 72 74 73 20 | 73 75 63 68 20 74 68 61 |o parts |such tha|
|00000540| 74 20 65 61 63 68 20 70 | 61 72 74 20 69 73 20 61 |t each p|art is a|
|00000550| 20 6d 69 6e 69 61 74 75 | 72 65 20 72 65 70 6c 69 | miniatu|re repli|
|00000560| 63 61 0d 0a 6f 66 20 6f | 6e 65 20 6f 66 20 74 68 |ca..of o|ne of th|
|00000570| 65 20 62 69 67 20 74 72 | 69 61 6e 67 6c 65 73 2e |e big tr|iangles.|
|00000580| 20 54 68 65 20 70 72 6f | 63 65 73 73 20 63 61 6e | The pro|cess can|
|00000590| 20 62 65 20 76 69 65 77 | 65 64 20 66 72 6f 6d 0d | be view|ed from.|
|000005a0| 0a 62 6f 74 74 6f 6d 20 | 75 70 20 28 61 73 73 65 |.bottom |up (asse|
|000005b0| 6d 62 6c 65 20 74 72 69 | 61 6e 67 6c 65 73 20 74 |mble tri|angles t|
|000005c0| 6f 20 66 6f 72 6d 20 62 | 69 67 67 65 72 20 6f 6e |o form b|igger on|
|000005d0| 65 73 29 20 6f 72 20 66 | 72 6f 6d 20 74 6f 70 20 |es) or f|rom top |
|000005e0| 64 6f 77 6e 0d 0a 20 28 | 64 65 63 6f 6d 70 6f 73 |down.. (|decompos|
|000005f0| 65 20 74 68 65 20 74 72 | 69 61 6e 67 6c 65 73 20 |e the tr|iangles |
|00000600| 75 6e 74 69 6c 20 74 68 | 65 79 20 61 72 65 20 73 |until th|ey are s|
|00000610| 6d 61 6c 6c 20 65 6e 6f | 75 67 68 29 2e 20 57 65 |mall eno|ugh). We|
|00000620| 20 63 68 6f 73 65 20 68 | 65 72 65 20 74 68 65 0d | chose h|ere the.|
|00000630| 0a 6c 61 74 74 65 72 20 | 61 70 70 72 6f 61 63 68 |.latter |approach|
|00000640| 2e 0d 0a 0d 0a 46 69 72 | 73 74 20 64 65 66 69 6e |.....Fir|st defin|
|00000650| 65 20 61 20 66 65 77 20 | 75 73 65 66 75 6c 20 63 |e a few |useful c|
|00000660| 6f 6e 73 74 61 6e 74 73 | 3a 20 24 5c 74 61 75 24 |onstants|: $\tau$|
|00000670| 20 69 73 20 74 68 65 20 | 67 6f 6c 64 65 6e 20 72 | is the |golden r|
|00000680| 61 74 69 6f 2c 0d 0a 24 | 5c 70 68 69 24 20 69 73 |atio,..$|\phi$ is|
|00000690| 20 24 5c 70 69 2f 35 24 | 2e 20 54 68 65 20 6c 61 | $\pi/5$|. The la|
|000006a0| 72 67 65 20 61 6e 64 20 | 73 6d 61 6c 6c 20 74 72 |rge and |small tr|
|000006b0| 69 61 6e 67 6c 65 73 20 | 68 61 76 65 20 73 69 64 |iangles |have sid|
|000006c0| 65 73 0d 0a 24 31 24 2c | 20 24 5c 74 61 75 24 2c |es..$1$,| $\tau$,|
|000006d0| 20 24 5c 74 61 75 24 20 | 61 6e 64 20 24 31 24 2c | $\tau$ |and $1$,|
|000006e0| 20 24 31 24 2c 20 24 5c | 74 61 75 24 20 72 65 73 | $1$, $\|tau$ res|
|000006f0| 70 65 63 74 69 76 65 6c | 79 2c 20 77 69 74 68 20 |pectivel|y, with |
|00000700| 61 6e 67 6c 65 73 0d 0a | 74 68 61 74 20 61 72 65 |angles..|that are|
|00000710| 20 6d 75 6c 74 69 70 6c | 65 73 20 6f 66 20 24 5c | multipl|es of $\|
|00000720| 70 68 69 24 2e 20 7c 63 | 73 69 7a 65 7c 20 69 73 |phi$. |c|size| is|
|00000730| 20 74 68 65 20 73 69 7a | 65 20 6f 66 20 74 68 65 | the siz|e of the|
|00000740| 20 63 69 72 63 6c 65 73 | 0d 0a 64 72 61 77 6e 20 | circles|..drawn |
|00000750| 61 74 20 74 68 65 20 74 | 72 69 61 6e 67 6c 65 73 |at the t|riangles|
|00000760| 27 73 75 6d 6d 69 74 73 | 2e 0d 0a 28 64 65 66 69 |'summits|...(defi|
|00000770| 6e 65 20 74 61 75 20 28 | 2f 20 28 2b 20 28 73 71 |ne tau (|/ (+ (sq|
|00000780| 72 74 20 35 29 20 31 29 | 20 32 29 29 0d 0a 28 64 |rt 5) 1)| 2))..(d|
|00000790| 65 66 69 6e 65 20 70 68 | 69 20 28 2f 20 70 69 20 |efine ph|i (/ pi |
|000007a0| 35 29 29 0d 0a 28 64 65 | 66 69 6e 65 20 63 73 69 |5))..(de|fine csi|
|000007b0| 7a 65 20 33 29 0d 0a 0d | 0a 54 68 69 73 20 70 72 |ze 3)...|.This pr|
|000007c0| 6f 63 65 64 75 72 65 20 | 69 73 20 68 61 6e 64 79 |ocedure |is handy|
|000007d0| 20 66 6f 72 20 64 6f 69 | 6e 67 20 70 6f 69 6e 74 | for doi|ng point|
|000007e0| 20 61 72 69 74 68 6d 65 | 74 69 63 2e 20 49 74 20 | arithme|tic. It |
|000007f0| 61 64 64 73 0d 0a 74 68 | 65 20 76 65 63 74 6f 72 |adds..th|e vector|
|00000800| 20 6f 66 20 6f 72 69 65 | 6e 74 61 74 69 6f 6e 20 | of orie|ntation |
|00000810| 7c 61 6e 67 6c 65 7c 20 | 28 69 6e 20 6d 75 6c 74 ||angle| |(in mult|
|00000820| 69 70 6c 65 73 20 6f 66 | 20 24 5c 70 68 69 24 29 |iples of| $\phi$)|
|00000830| 20 61 6e 64 0d 0a 6c 65 | 6e 67 74 68 20 7c 73 69 | and..le|ngth |si|
|00000840| 7a 65 7c 20 74 6f 20 74 | 68 65 20 70 6f 69 6e 74 |ze| to t|he point|
|00000850| 20 7c 70 7c 2e 0d 0a 28 | 64 65 66 69 6e 65 20 28 | |p|...(|define (|
|00000860| 70 2b 20 70 6f 69 6e 74 | 20 73 69 7a 65 20 61 6e |p+ point| size an|
|00000870| 67 6c 65 29 0d 0a 20 20 | 28 63 6f 6e 73 20 28 2b |gle).. |(cons (+|
|00000880| 20 28 63 61 72 20 70 6f | 69 6e 74 29 20 28 2a 20 | (car po|int) (* |
|00000890| 73 69 7a 65 20 28 63 6f | 73 20 28 2a 20 61 6e 67 |size (co|s (* ang|
|000008a0| 6c 65 20 70 68 69 29 29 | 29 29 0d 0a 20 20 20 20 |le phi))|)).. |
|000008b0| 20 20 20 20 28 2b 20 28 | 63 64 72 20 70 6f 69 6e | (+ (|cdr poin|
|000008c0| 74 29 20 28 2a 20 73 69 | 7a 65 20 28 73 69 6e 20 |t) (* si|ze (sin |
|000008d0| 28 2a 20 61 6e 67 6c 65 | 20 70 68 69 29 29 29 29 |(* angle| phi))))|
|000008e0| 29 29 0d 0a 0d 0a 48 65 | 72 65 20 77 65 20 61 63 |))....He|re we ac|
|000008f0| 74 75 61 6c 6c 79 20 64 | 72 61 77 20 61 20 74 72 |tually d|raw a tr|
|00000900| 69 61 6e 67 6c 65 20 6f | 66 20 63 6f 6f 72 64 69 |iangle o|f coordi|
|00000910| 6e 61 74 65 73 20 7c 61 | 7c 2c 0d 0a 7c 62 7c 20 |nates |a||,..|b| |
|00000920| 61 6e 64 20 7c 63 7c 2e | 20 54 68 65 20 62 6f 6f |and |c|.| The boo|
|00000930| 6c 65 61 6e 20 70 61 72 | 61 6d 65 74 65 72 73 20 |lean par|ameters |
|00000940| 7c 70 61 7c 2c 20 7c 70 | 62 7c 20 61 6e 64 20 7c ||pa|, |p|b| and ||
|00000950| 70 63 7c 20 69 6e 64 69 | 63 61 74 65 0d 0a 77 68 |pc| indi|cate..wh|
|00000960| 65 74 68 65 72 20 74 68 | 65 20 73 75 6d 6d 69 74 |ether th|e summit|
|00000970| 20 69 73 20 68 6f 6c 6c | 6f 77 20 28 69 66 20 66 | is holl|ow (if f|
|00000980| 61 6c 73 65 29 20 61 20 | 66 69 6c 6c 65 64 20 28 |alse) a |filled (|
|00000990| 69 66 20 74 72 75 65 29 | 2e 0d 0a 28 64 65 66 69 |if true)|...(defi|
|000009a0| 6e 65 20 28 74 72 69 61 | 6e 67 6c 65 20 61 20 62 |ne (tria|ngle a b|
|000009b0| 20 63 20 70 61 20 70 62 | 20 70 63 29 0d 0a 20 20 | c pa pb| pc).. |
|000009c0| 28 6c 65 74 20 28 28 70 | 6c 69 73 74 20 28 6d 61 |(let ((p|list (ma|
|000009d0| 70 20 28 6c 61 6d 62 64 | 61 20 28 70 6f 69 6e 74 |p (lambd|a (point|
|000009e0| 29 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |).. | |
|000009f0| 20 20 20 20 20 20 20 20 | 20 28 63 6f 6e 73 20 28 | | (cons (|
|00000a00| 72 6f 75 6e 64 20 28 63 | 61 72 20 70 6f 69 6e 74 |round (c|ar point|
|00000a10| 29 29 0d 0a 20 20 20 20 | 20 20 20 20 20 20 20 20 |)).. | |
|00000a20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000a30| 28 72 6f 75 6e 64 20 28 | 63 64 72 20 70 6f 69 6e |(round (|cdr poin|
|00000a40| 74 29 29 29 29 0d 0a 20 | 20 20 20 20 20 20 20 20 |t)))).. | |
|00000a50| 20 20 20 20 20 20 20 20 | 20 20 20 28 6c 69 73 74 | | (list|
|00000a60| 20 62 20 63 20 61 29 29 | 29 0d 0a 20 20 20 20 20 | b c a))|).. |
|00000a70| 20 20 20 28 66 69 6c 6c | 20 28 6c 61 6d 62 64 61 | (fill| (lambda|
|00000a80| 20 28 70 6f 69 6e 74 29 | 0d 0a 09 20 20 28 66 69 | (point)|... (fi|
|00000a90| 6c 6c 2d 65 6c 6c 69 70 | 73 65 20 70 6f 69 6e 74 |ll-ellip|se point|
|00000aa0| 20 28 63 6f 6e 73 20 63 | 73 69 7a 65 20 63 73 69 | (cons c|size csi|
|00000ab0| 7a 65 29 29 29 29 0d 0a | 20 20 20 20 20 20 20 20 |ze))))..| |
|00000ac0| 28 6f 75 74 6c 69 6e 65 | 20 28 6c 61 6d 62 64 61 |(outline| (lambda|
|00000ad0| 20 28 70 6f 69 6e 74 29 | 0d 0a 09 20 20 28 65 6c | (point)|... (el|
|00000ae0| 6c 69 70 73 65 20 70 6f | 69 6e 74 20 30 20 33 36 |lipse po|int 0 36|
|00000af0| 30 20 28 63 6f 6e 73 20 | 63 73 69 7a 65 20 63 73 |0 (cons |csize cs|
|00000b00| 69 7a 65 29 29 29 29 29 | 0d 0a 20 20 20 20 28 64 |ize)))))|.. (d|
|00000b10| 72 61 77 2d 70 6f 6c 79 | 20 28 63 6f 6e 73 20 28 |raw-poly| (cons (|
|00000b20| 63 61 64 64 72 20 70 6c | 69 73 74 29 20 70 6c 69 |caddr pl|ist) pli|
|00000b30| 73 74 29 29 0d 0a 20 20 | 20 20 28 28 69 66 20 70 |st)).. | ((if p|
|00000b40| 62 20 66 69 6c 6c 20 6f | 75 74 6c 69 6e 65 29 20 |b fill o|utline) |
|00000b50| 28 63 61 72 20 70 6c 69 | 73 74 29 29 0d 0a 20 20 |(car pli|st)).. |
|00000b60| 20 20 28 28 69 66 20 70 | 63 20 66 69 6c 6c 20 6f | ((if p|c fill o|
|00000b70| 75 74 6c 69 6e 65 29 20 | 28 63 61 64 72 20 70 6c |utline) |(cadr pl|
|00000b80| 69 73 74 29 29 0d 0a 20 | 20 20 20 28 28 69 66 20 |ist)).. | ((if |
|00000b90| 70 61 20 66 69 6c 6c 20 | 6f 75 74 6c 69 6e 65 29 |pa fill |outline)|
|00000ba0| 20 28 63 61 64 64 72 20 | 70 6c 69 73 74 29 29 29 | (caddr |plist)))|
|00000bb0| 29 0d 0a 0d 0a 54 68 69 | 73 20 69 73 20 74 68 65 |)....Thi|s is the|
|00000bc0| 20 61 63 74 75 61 6c 20 | 72 65 63 75 72 73 69 76 | actual |recursiv|
|00000bd0| 65 20 63 6f 64 65 2e 0d | 0a 49 74 20 77 69 6c 6c |e code..|.It will|
|00000be0| 20 64 72 61 77 20 61 20 | 6c 61 72 67 65 20 74 72 | draw a |large tr|
|00000bf0| 69 61 6e 67 6c 65 20 61 | 74 20 70 6f 73 69 74 69 |iangle a|t positi|
|00000c00| 6f 6e 20 70 61 69 72 20 | 7c 70 6f 73 69 74 69 6f |on pair ||positio|
|00000c10| 6e 7c 2c 20 77 69 74 68 | 20 6c 65 6e 67 74 68 73 |n|, with| lengths|
|00000c20| 0d 0a 7c 73 69 7a 65 7c | 20 6f 72 20 24 5c 74 61 |..|size|| or $\ta|
|00000c30| 75 7c 73 69 7a 65 7c 24 | 2c 20 72 6f 74 61 74 65 |u|size|$|, rotate|
|00000c40| 64 20 24 5c 70 68 69 7c | 61 6e 67 6c 65 7c 24 2e |d $\phi||angle|$.|
|00000c50| 20 7c 4f 72 69 65 6e 74 | 61 74 69 6f 6e 7c 20 69 | |Orient|ation| i|
|00000c60| 6e 64 69 63 61 74 65 73 | 0d 0a 77 68 65 74 68 65 |ndicates|..whethe|
|00000c70| 72 20 74 68 65 20 63 6f | 6c 6f 75 72 69 6e 67 20 |r the co|louring |
|00000c80| 73 63 68 65 6d 65 20 69 | 73 20 73 74 61 6e 64 61 |scheme i|s standa|
|00000c90| 72 64 20 6f 72 20 72 65 | 76 65 72 73 65 64 2c 20 |rd or re|versed, |
|00000ca0| 61 6e 64 20 7c 6c 65 76 | 65 6c 7c 20 69 73 0d 0a |and |lev|el| is..|
|00000cb0| 74 68 65 20 72 65 63 75 | 72 73 69 6f 6e 20 6c 65 |the recu|rsion le|
|00000cc0| 76 65 6c 2c 20 6f 66 20 | 63 6f 75 72 73 65 2e 0d |vel, of |course..|
|00000cd0| 0a 28 64 65 66 69 6e 65 | 20 28 6c 20 70 6f 73 69 |.(define| (l posi|
|00000ce0| 74 69 6f 6e 20 73 69 7a | 65 20 61 6e 67 6c 65 20 |tion siz|e angle |
|00000cf0| 6f 72 69 65 6e 74 61 74 | 69 6f 6e 20 6c 65 76 65 |orientat|ion leve|
|00000d00| 6c 29 0d 0a 20 20 28 6c | 65 74 20 28 28 73 69 7a |l).. (l|et ((siz|
|00000d10| 65 2f 74 61 75 20 28 2f | 20 73 69 7a 65 20 74 61 |e/tau (/| size ta|
|00000d20| 75 29 29 0d 0a 20 20 20 | 20 20 20 20 20 28 73 69 |u)).. | (si|
|00000d30| 7a 65 2a 74 61 75 20 28 | 2a 20 73 69 7a 65 20 74 |ze*tau (|* size t|
|00000d40| 61 75 29 29 0d 0a 20 20 | 20 20 20 20 20 20 28 64 |au)).. | (d|
|00000d50| 6f 6c 20 28 6c 61 6d 62 | 64 61 20 28 64 73 20 64 |ol (lamb|da (ds d|
|00000d60| 61 20 6e 73 20 6e 61 20 | 6e 6f 29 0d 0a 20 20 20 |a ns na |no).. |
|00000d70| 20 20 20 20 20 20 20 28 | 6c 20 28 70 2b 20 70 6f | (|l (p+ po|
|00000d80| 73 69 74 69 6f 6e 20 64 | 73 20 28 2b 20 61 6e 67 |sition d|s (+ ang|
|00000d90| 6c 65 20 64 61 29 29 20 | 6e 73 20 28 2b 20 61 6e |le da)) |ns (+ an|
|00000da0| 67 6c 65 20 6e 61 29 0d | 0a 09 20 20 20 20 20 28 |gle na).|.. (|
|00000db0| 65 71 3f 20 6e 6f 20 6f | 72 69 65 6e 74 61 74 69 |eq? no o|rientati|
|00000dc0| 6f 6e 29 20 28 2d 20 6c | 65 76 65 6c 20 31 29 29 |on) (- l|evel 1))|
|00000dd0| 29 29 0d 0a 20 20 20 20 | 20 20 20 20 28 64 6f 73 |)).. | (dos|
|00000de0| 20 28 6c 61 6d 62 64 61 | 20 28 64 73 20 64 61 20 | (lambda| (ds da |
|00000df0| 6e 73 20 6e 61 20 6e 6f | 29 0d 0a 20 20 20 09 20 |ns na no|).. . |
|00000e00| 20 28 73 20 28 70 2b 20 | 70 6f 73 69 74 69 6f 6e | (s (p+ |position|
|00000e10| 20 64 73 20 28 2b 20 61 | 6e 67 6c 65 20 64 61 29 | ds (+ a|ngle da)|
|00000e20| 29 20 6e 73 20 28 2b 20 | 61 6e 67 6c 65 20 6e 61 |) ns (+ |angle na|
|00000e30| 29 0d 0a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |).. | |
|00000e40| 28 65 71 3f 20 6e 6f 20 | 6f 72 69 65 6e 74 61 74 |(eq? no |orientat|
|00000e50| 69 6f 6e 29 20 28 2d 20 | 6c 65 76 65 6c 20 31 29 |ion) (- |level 1)|
|00000e60| 29 29 29 29 0d 0a 20 20 | 20 20 0d 0a 20 20 20 20 |)))).. | .. |
|00000e70| 28 69 66 20 28 3d 20 6c | 65 76 65 6c 20 30 29 0d |(if (= l|evel 0).|
|00000e80| 0a 20 20 20 20 20 20 20 | 20 28 74 72 69 61 6e 67 |. | (triang|
|00000e90| 6c 65 20 70 6f 73 69 74 | 69 6f 6e 0d 0a 09 09 20 |le posit|ion.... |
|00000ea0| 20 28 70 2b 20 70 6f 73 | 69 74 69 6f 6e 20 28 2a | (p+ pos|ition (*|
|00000eb0| 20 73 69 7a 65 20 74 61 | 75 29 20 28 2b 20 61 6e | size ta|u) (+ an|
|00000ec0| 67 6c 65 20 32 29 29 0d | 0a 09 09 20 20 28 70 2b |gle 2)).|... (p+|
|00000ed0| 20 70 6f 73 69 74 69 6f | 6e 20 73 69 7a 65 20 61 | positio|n size a|
|00000ee0| 6e 67 6c 65 29 0d 0a 09 | 09 20 20 28 6e 6f 74 20 |ngle)...|. (not |
|00000ef0| 6f 72 69 65 6e 74 61 74 | 69 6f 6e 29 20 23 74 20 |orientat|ion) #t |
|00000f00| 6f 72 69 65 6e 74 61 74 | 69 6f 6e 29 0d 0a 20 20 |orientat|ion).. |
|00000f10| 20 20 20 20 20 20 28 69 | 66 20 28 6f 64 64 3f 20 | (i|f (odd? |
|00000f20| 6c 65 76 65 6c 29 0d 0a | 20 20 20 20 20 20 20 20 |level)..| |
|00000f30| 20 20 20 20 28 69 66 20 | 6f 72 69 65 6e 74 61 74 | (if |orientat|
|00000f40| 69 6f 6e 0d 0a 20 20 20 | 20 20 20 20 20 20 20 20 |ion.. | |
|00000f50| 20 20 20 20 20 28 62 65 | 67 69 6e 20 28 64 6f 6c | (be|gin (dol|
|00000f60| 20 73 69 7a 65 20 31 20 | 73 69 7a 65 2f 74 61 75 | size 1 |size/tau|
|00000f70| 20 37 20 23 66 29 0d 0a | 09 09 20 20 20 20 20 20 | 7 #f)..|.. |
|00000f80| 20 28 64 6f 73 20 73 69 | 7a 65 20 31 20 73 69 7a | (dos si|ze 1 siz|
|00000f90| 65 2f 74 61 75 20 36 20 | 23 74 29 29 0d 0a 20 20 |e/tau 6 |#t)).. |
|00000fa0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 28 62 | | (b|
|00000fb0| 65 67 69 6e 20 28 64 6f | 6c 20 73 69 7a 65 20 30 |egin (do|l size 0|
|00000fc0| 20 73 69 7a 65 2f 74 61 | 75 20 33 20 23 66 29 0d | size/ta|u 3 #f).|
|00000fd0| 0a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |. | |
|00000fe0| 20 20 20 20 20 20 20 20 | 28 64 6f 73 20 73 69 7a | |(dos siz|
|00000ff0| 65 2a 74 61 75 20 30 20 | 73 69 7a 65 2f 74 61 75 |e*tau 0 |size/tau|
|00001000| 20 34 20 23 74 29 29 29 | 0d 0a 20 20 20 20 20 20 | 4 #t)))|.. |
|00001010| 20 20 20 20 20 20 28 69 | 66 20 6f 72 69 65 6e 74 | (i|f orient|
|00001020| 61 74 69 6f 6e 0d 0a 20 | 20 20 20 20 20 20 20 20 |ation.. | |
|00001030| 20 20 20 20 20 20 20 28 | 62 65 67 69 6e 20 28 64 | (|begin (d|
|00001040| 6f 6c 20 73 69 7a 65 2a | 74 61 75 20 32 20 73 69 |ol size*|tau 2 si|
|00001050| 7a 65 20 37 20 23 74 29 | 0d 0a 20 20 20 20 20 20 |ze 7 #t)|.. |
|00001060| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00001070| 20 28 64 6f 73 20 73 69 | 7a 65 20 30 20 73 69 7a | (dos si|ze 0 siz|
|00001080| 65 2f 74 61 75 20 33 20 | 23 74 29 29 0d 0a 20 20 |e/tau 3 |#t)).. |
|00001090| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 28 62 | | (b|
|000010a0| 65 67 69 6e 20 28 64 6f | 6c 20 73 69 7a 65 20 30 |egin (do|l size 0|
|000010b0| 20 73 69 7a 65 20 33 20 | 23 74 29 0d 0a 20 20 20 | size 3 |#t).. |
|000010c0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000010d0| 20 20 20 20 28 64 6f 73 | 20 73 69 7a 65 2f 74 61 | (dos| size/ta|
|000010e0| 75 20 32 20 73 69 7a 65 | 2f 74 61 75 20 37 20 23 |u 2 size|/tau 7 #|
|000010f0| 74 29 29 29 29 29 29 29 | 0d 0a 0d 0a 28 64 65 66 |t)))))))|....(def|
|00001100| 69 6e 65 20 28 73 20 70 | 6f 73 69 74 69 6f 6e 20 |ine (s p|osition |
|00001110| 73 69 7a 65 20 61 6e 67 | 6c 65 20 6f 72 69 65 6e |size ang|le orien|
|00001120| 74 61 74 69 6f 6e 20 6c | 65 76 65 6c 29 0d 0a 20 |tation l|evel).. |
|00001130| 20 28 69 66 20 28 3d 20 | 6c 65 76 65 6c 20 30 29 | (if (= |level 0)|
|00001140| 0d 0a 20 20 20 20 20 20 | 28 74 72 69 61 6e 67 6c |.. |(triangl|
|00001150| 65 20 70 6f 73 69 74 69 | 6f 6e 0d 0a 20 20 20 20 |e positi|on.. |
|00001160| 20 20 20 20 20 20 20 20 | 20 20 20 20 28 70 2b 20 | | (p+ |
|00001170| 70 6f 73 69 74 69 6f 6e | 20 73 69 7a 65 20 28 2b |position| size (+|
|00001180| 20 61 6e 67 6c 65 20 31 | 29 29 0d 0a 09 09 28 70 | angle 1|))....(p|
|00001190| 2b 20 70 6f 73 69 74 69 | 6f 6e 20 28 2a 20 73 69 |+ positi|on (* si|
|000011a0| 7a 65 20 74 61 75 29 20 | 61 6e 67 6c 65 29 0d 0a |ze tau) |angle)..|
|000011b0| 09 09 6f 72 69 65 6e 74 | 61 74 69 6f 6e 20 23 66 |..orient|ation #f|
|000011c0| 20 28 6e 6f 74 20 6f 72 | 69 65 6e 74 61 74 69 6f | (not or|ientatio|
|000011d0| 6e 29 29 0d 0a 20 20 20 | 20 20 20 28 6c 20 70 6f |n)).. | (l po|
|000011e0| 73 69 74 69 6f 6e 20 73 | 69 7a 65 20 61 6e 67 6c |sition s|ize angl|
|000011f0| 65 20 6f 72 69 65 6e 74 | 61 74 69 6f 6e 20 28 2d |e orient|ation (-|
|00001200| 20 6c 65 76 65 6c 20 31 | 29 29 29 29 0d 0a 0d 0a | level 1|))))....|
|00001210| 46 69 6e 61 6c 6c 79 20 | 61 20 66 65 77 20 73 68 |Finally |a few sh|
|00001220| 6f 72 74 68 61 6e 64 73 | 2e 0d 0a 28 64 65 66 69 |orthands|...(defi|
|00001230| 6e 65 20 28 69 29 0d 0a | 20 20 28 69 6e 69 74 2d |ne (i)..| (init-|
|00001240| 67 72 61 70 68 29 0d 0a | 20 20 28 73 70 6c 69 74 |graph)..| (split|
|00001250| 2d 73 63 72 65 65 6e 20 | 31 30 29 29 0d 0a 28 64 |-screen |10))..(d|
|00001260| 65 66 69 6e 65 20 63 20 | 63 6c 6f 73 65 2d 67 72 |efine c |close-gr|
|00001270| 61 70 68 29 0d 0a 28 64 | 65 66 69 6e 65 20 64 20 |aph)..(d|efine d |
|00001280| 63 6c 65 61 72 2d 64 65 | 76 69 63 65 29 0d 0a 5c |clear-de|vice)..\|
|00001290| 65 6e 64 7b 64 6f 63 75 | 6d 65 6e 74 7d 0d 0a |end{docu|ment}.. |
+--------+-------------------------+-------------------------+--------+--------+